| Total Complexity | 3 |
| Total Lines | 25 |
| Duplicated Lines | 0 % |
| Changes | 0 | ||
| 1 | import { LeaveRequest, Type } from './LeaveRequest.entity'; |
||
| 2 | |||
| 3 | export class UserLeavesCollection { |
||
| 4 | public paid: LeaveRequest[] = []; |
||
| 5 | public unpaid: LeaveRequest[] = []; |
||
| 6 | public special: LeaveRequest[] = []; |
||
| 7 | public medical: LeaveRequest[] = []; |
||
| 8 | |||
| 9 | constructor(leaves: LeaveRequest[]) { |
||
| 10 | this.distributeLeavesByType(leaves); |
||
| 11 | } |
||
| 12 | |||
| 13 | private distributeLeavesByType(leaves: LeaveRequest[]): void { |
||
| 14 | for (const leave of leaves) { |
||
| 15 | switch (leave.getType()) { |
||
| 16 | case Type.PAID: |
||
| 17 | this.paid.push(leave); |
||
| 18 | break; |
||
| 19 | case Type.UNPAID: |
||
| 20 | this.unpaid.push(leave); |
||
| 21 | break; |
||
| 22 | case Type.SPECIAL: |
||
| 23 | this.special.push(leave); |
||
| 24 | break; |
||
| 25 | case Type.MEDICAL: |
||
| 26 | this.medical.push(leave); |
||
| 27 | } |
||
| 31 |